## Digital System Design

Lecture 13

**Combinational Logic Design** 

Binary Multipliers and Decoders

**Objectives:** 

- **1. Multipliers:** 
  - Multiplication of two 2-bit numbers. 1.1
  - **1.2** Combinational circuit of binary multiplier with more bits.
- 2. Decoders:
  - 2.1) 2x4 decoder (Active-high).
  - 2.2) Active-low decoders.
  - 2.3) Decoders with enable inputs.
  - 2.4) Three-to-eight-line decoder circuit.
  - 2.5) Larger decoder circuit.
  - 2.6) Combinational logic implementation.

#### 1) **Multipliers:**

- > Multiplication of binary numbers is performed in the same way as multiplication of decimal numbers:
  - **1.1 Multiplication of two 2-bit numbers.**



### **Combinational circuit**

- > The multiplication of two bits such as  $A_0$  and  $B_0$  produces a I if both bits are I; otherwise, it produces a 0, this is identical to an **AND** operation.
- > The two partial products are added with two half-adder (*HA*) circuits (if there are more than two bits, we must use full adder (*FA*)).



# 1.2 Combinational circuit of binary multiplier with more bits. For J bits multiplier and K bits multiplicand, we need:

 $J \times K$  AND gates.

(J-1)K-bits adders to produce a product of J + K bits.

**Example: -** Create a logic circuit for

$$\begin{array}{c}
 B_{3}B_{2}B_{1}B_{0} \\
 A_{2}A_{1}A_{0} \\
\hline
 C_{6}C_{5}C_{4}C_{3}C_{2}C_{1}C_{0} \\
\end{array} \times$$
Answer

Solution:

K = 4J = 3

So:

We need 12 AND gates and 2 four-bit adders to produce a product of seven bits:  $C_6C_5C_4C_3C_2C_1C_0$ .



### Circuit Implementation:



### 2) Decoders

- > Information is represented in digital system by binary codes. A binary code of n bits is capable of representing up to  $2^n$  distinct elements of coded information.
- > A *decoder* is a combinational circuit that covers binary information from n input lines to a maximum of  $2^n$  unique output lines.
- > The decoders are called n to m line decoders, where  $m \le 2^n$  (for example **BCD-to-seven-segment decoder**, 3 to 8 decoder).
- > The purpose of the decoders is to **generate** the  $2^n$  (or fewer) minterms of n input variables.
- Decoder is a circuit that allows us to activate an output line by specifying a control word; it is either active-high or active-low.
  - Active-high sets a particular output to logic 1. While remaining other outputs to logic 0.
  - Active-low sets a particular output to logic 0, other outputs to logic 1.



1. 
$$S_1 = 0$$
,  $S_0 = 0 \Rightarrow D_0 = 1$   
 $D_0 = \overline{S_1} \cdot \overline{S_0}$ ;  $D_1 = D_2 = D_3 = 0$   
2.  $S_1 = 0$ ,  $S_0 = 1 \Rightarrow D_1 = 1$   
 $D_1 = \overline{S_1} \cdot S_0$ ;  $D_0 = D_2 = D_3 = 0$   
3.  $S_1 = 1$ ,  $S_0 = 0 \Rightarrow D_2 = 1$   
 $D_2 = S_1 \cdot \overline{S_0}$ ;  $D_0 = D_1 = D_3 = 0$   
4.  $S_1 = 1$ ,  $S_0 = 1 \Rightarrow D_3 = 1$   
 $D_3 = S_1 \cdot S_0$ ;  $D_0 = D_1 = D_2 = 0$ 

| Inp<br>Select         |       | Output<br>Output Lines |       |                       |       |  |  |
|-----------------------|-------|------------------------|-------|-----------------------|-------|--|--|
| <i>S</i> <sub>1</sub> | $S_0$ |                        | $D_2$ | <b>D</b> <sub>1</sub> | $D_0$ |  |  |
| 0                     | 0     | 0                      | 0     | 0                     | 1     |  |  |
| 0                     | 1     | 0                      | 0     | 1                     | 0     |  |  |
| 1                     | 0     | 0                      | 1     | 0                     | 0     |  |  |
| 1                     | 1     | 1                      | 0     | 0                     | 0     |  |  |
| Truth table           |       |                        |       |                       |       |  |  |

### > From truth table:

- $\checkmark\,$  Two inputs are decoded to 4 outputs.
- ✓ Each output represents one of the minterms of the three input variables.
- $\checkmark$  For each possible combination (input), there are 3 outputs that are equal to 0 and only one that is equal to 1.







| Inputs<br>Select<br>Lines |                       | Output<br>Output Lines |                       |                       |       |  |  |
|---------------------------|-----------------------|------------------------|-----------------------|-----------------------|-------|--|--|
| <i>S</i> <sub>1</sub>     | <i>S</i> <sub>0</sub> | $D_3$                  | <b>D</b> <sub>2</sub> | <b>D</b> <sub>1</sub> | $D_0$ |  |  |
| 0                         | 0                     | 1                      | 1                     | 1                     | 0     |  |  |
| 0                         | 1                     | 1                      | 1                     | 0                     | 1     |  |  |
| 1                         | 0                     | 1                      | 0                     | 1                     | 1     |  |  |
| 1                         | 1                     | 0                      | 1                     | 1                     | 1     |  |  |
| Truth table               |                       |                        |                       |                       |       |  |  |

## AND becomes NAND

 $D_{0} = \overline{\overline{S_{1}} \ \overline{S_{0}}} \quad Complement$   $= S_{1} + S_{0}$   $D_{1} = \overline{\overline{S_{1}} \ S_{0}} = S_{1} + \overline{S_{0}};$   $D_{2} = \overline{S_{1}} + S_{0};$   $D_{3} = \overline{S_{1}} + \overline{S_{0}};$ 

### 2.3) Decoders with enable inputs

- Some decoders include one or more *enable inputs* to control the circuit operation.
- A two-to-four line decoder with an **enable input**\_constructed with **NAND** gate is the following:

|   | Inpu                  | ıts            | Output<br>Output Lines |       |                       |       |  |  |  |
|---|-----------------------|----------------|------------------------|-------|-----------------------|-------|--|--|--|
| E | <i>S</i> <sub>1</sub> | S <sub>0</sub> | $D_3$                  | $D_2$ | <b>D</b> <sub>1</sub> | $D_0$ |  |  |  |
| 1 | X                     | X              | 1                      | 1     | 1                     | 1     |  |  |  |
| 0 | 0                     | 0              | 1                      | 1     | 1                     | 0     |  |  |  |
| 0 | 0                     | 1              | 1                      | 1     | 0                     | 1     |  |  |  |
| 0 | 1                     | 0              | 1                      | 0     | 1                     | 1     |  |  |  |
| 0 | 1                     | 1              | 0                      | 1     | 1                     | 1     |  |  |  |
|   | Truth table           |                |                        |       |                       |       |  |  |  |



with enable input

- The circuit operates with complemented output and a complemented enable input (Active-Low Enable):
  - $\checkmark E = 0$  then the decoder is enabled.
  - $\checkmark E = 1$  then the decoder is disabled.
- > The enable input may be active with 0 or with a 1 signal.

### 2.4) Three-to-eight-line decoder circuit

| inputs |   |   | outputs               |                       |                       |                       |                       |                       |                       |                       |
|--------|---|---|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|
| X      | Y | Ζ | <b>D</b> <sub>0</sub> | <b>D</b> <sub>1</sub> | <b>D</b> <sub>2</sub> | <b>D</b> <sub>3</sub> | <b>D</b> <sub>4</sub> | <b>D</b> <sub>5</sub> | <b>D</b> <sub>6</sub> | <b>D</b> <sub>7</sub> |
| 0      | 0 | 0 | 1                     | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     |
| 0      | 0 | 1 | 0                     | 1                     | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     |
| 0      | 1 | 0 | 0                     | 0                     | 1                     | 0                     | 0                     | 0                     | 0                     | 0                     |
| 0      | 1 | 1 | 0                     | 0                     | 0                     | 1                     | 0                     | 0                     | 0                     | 0                     |
| 1      | 0 | 0 | 0                     | 0                     | 0                     | 0                     | 1                     | 0                     | 0                     | 0                     |
| 1      | 0 | 1 | 0                     | 0                     | 0                     | 0                     | 0                     | 1                     | 0                     | 0                     |
| 1      | 1 | 0 | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 1                     | 0                     |
| 1      | 1 | 1 | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     | 1                     |



### 2.5) Larger decoder circuit.

- Decoders with enable inputs can be connected together to form a larger decoder circuit.
- > To design a 4 to 16 line decoder. Using two 3 to 8 decoders with enable inputs, we do the following connection:
  - ✓ When W = 0 the top decoder is enable and the other is disable: The bottom decoder outputs are all 0's and the top eight outputs generate minterms 0000 to 0111.
  - ✓ When W = 1 the enable condition is reversed, the bottom decoder outputs generate minterms 1000 to 1111.



### 2.6) Combinational logic implementation:

- > Since, a decoder provides the  $2^n$  minterms of n input, and any Boolean function can be expressed in sum-of-minterms form, A decoder that generates the minterms of the functions, together with an *external OR gate* that forms their logical sum, provides a hardware implementation of the function.
- > In this way, any combinational circuit with n inputs and m outputs can be implemented using  $n to 2^n$  line decoder and m OR gates.
- The procedure for implementing a combinational circuit by means of decoders and OR gates requires that the Boolean function for the circuit be expressed as a sum of minterms.

### **Example:**-Implementation a full-adder circuit using the decoders.

From the truth table of the full adder, we obtain the functions for the sum and carry in sum-of-minterms form:

$$S(X, Y, C_{in}) = \sum (1, 2, 4, 7)$$
$$C_{out}(X, Y, C_{in}) = \sum (3, 5, 6, 7)$$

> We have *3 inputs*: so, we need a *three-to-eight line decoder*.

